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Abstract 

We consider the fundamental algorithmic problem of finding a cycle of minimum weight in a weighted graph. 
In particular, we show that the minimum weight cycle problem in an undirected n-node graph with edge weights 
in {!,..., M} or in a directed n-node graph with edge weights in {— M, ...,M} and no negative cycles can 
be efficiently reduced to finding a minimum weight triangle in an O(n)— node undirected graph with weights in 
{f , . . . , O(M)}. Roughly speaking, our reductions imply the following surprising phenomenon: a minimum cycle 
with an arbitrary number of weighted edges can be "encoded" using only three edges within roughly the same 
weight interval! 

This resolves a longstanding open problem posed in a seminal work by Itai and Rodeh [SIAM J. Computing 
1978 and STOC'77] on minimum cycle in unweighted graphs. 

A direct consequence of our efficient reductions are 6(Mn u ) < 0(Mn 2 376 )-time algorithms using fast matrix 
multiplication (FMM) for finding a minimum weight cycle in both undirected graphs with integral weights from 
the interval [1, M] and directed graphs with integral weights from the interval [—M,M]. The latter seems to 
reveal a strong separation between the all pairs shortest paths (APSP) problem and the minimum weight cycle 
problem in directed graphs as the fastest known APSP algorithm has a running time of 0(M°- 68 V- 575 ) by Zwick 
[J. ACM 2002]. 

In contrast, when only combinatorial algorithms are allowed (that is, without FMM) the only known solution 
to minimum weight cycle is by computing APSP. Interestingly, any separation between the two problems in this 
case would be an amazing breakthrough as by a recent paper by Vassilevska W. and Williams [FOCST0], any 
0(n 3-e )-time algorithm (e > 0) for minimum weight cycle immediately implies a 0(n 3 ~' 5 )-time algorithm (8 > 0) 
for APSP. 



1 Introduction 



We consider the algorithmic problem of finding a minimum weight cycle (i.e., weighted girth) in weighted directed 
and undirected graphs. Surprisingly, although the problem is very fundamental, the state of the art for it dates back 
to a seminal paper by Itai and Rodeh P3], first presented in STOC'77, that deals only with the unweighted variant 
of the problem. Itai and Rodeh presented an 0(n LJ )-tmie algorithm for an n-node unweighted undirected graph and 
an (9(n w log n)-time algorithm for an n-node unweighted directed graph. (Here w is the exponent of square matrix 
multiplication over a ring, and w < 2.376 ,6 .) In the same paper, Itai and Rodeh posed the question whether similar 
results exist for weighted graphs. In this paper we provide a positive answer to this longstanding open problem 
by presenting 0(Mn")-time algorithms for directed graphs with integral edge weights in [—M,M] (and no negative 
cycles) and for undirected graphs with integral edge weights in [1, M]. 

Our algorithmic results are obtained using new reductions that carefully combine new algorithmic ideas and 
special combinatorial properties of the minimum weight cycle. More specifically, we reduce the problem to the 
problem of finding a minimum weight triangle in a 0(n)— node undirected graph with weights in {1, . . . , O(M)}. 
This reveals also a surprising phenomenon: a minimum cycle with an arbitrary number of weighted edges can be 
efficiently "encoded" using a cycle of only three edges whose weights are roughly within the same interval! Moreover, 
our results imply a strong equivalence between the cycle and triangle problems. 

Minimum cycle and APSP. Recently, in FOCSTO Vassilevska W. and Williams [H] showed that the minimum 
weight cycle problem is equivalent to many other graph and matrix problems for which no truly subcubic (0(n 3 ~ e )- 
time for constant e > 0) algorithms are known. They showed that if there is a truly subcubic algorithm for the 
minimum weight cycle problem, then many other problems such as the all-pairs-shortest-paths (APSP) problem also 
have truly subcubic algorithms. Hence, the minimum weight cycle problem has a pivotal role in understanding the 
complexity of many fundamental polynomial problems in a similar spirit to the role of 3SAT for NP-hard problems. 

It is interesting to compare the minimum cycle problem with APSP. In directed graphs, the minimum weight cycle 
can be computed easily by computing APSP. Given the distance d[u, v] between all pairs of vertices u, v, the weight of 
the minimum cycle is min Ujt , w(u, v) + d[v, u\. Hence, we can compute the minimum weight cycle in cubic time using 
Floyd- Warshall's APSP algorithm 8, 23 j (or Pettie's 0(mn + n 2 log log n) time algorithm [18j if the graph is sparse). 
If the edge weights are integers in [—M,M], we can use Zwick's [27] O(M - 681 n 2 575 ) time algorithm to obtain an 
algorithm for minimum cycle with the same runtime. Improving Zwick's running time and in particular obtaining 
an 0{Mn u} ) running time for APSP in directed graphs is one of today's frontier questions in graph algorithms. Our 
new 0(Mn u )-time algorithm for minimum cycle in directed graphs shows that it is not really necessary to compute 
all pairs shortest paths in order to compute the minimum weight cycle in directed graphs. This seems to reveal a 
strong separation between APSP and the minimum cycle problem in directed graphs. 

The minimum cycle problem in undirected graphs differs from the problem in directed graphs in that the reduction 
to APSP no longer works: an edge (u, v) might also be the shortest path from v to u, and min Ui „ w(u, v) +d[v,u] 
might be 2w(u, v) and not the weighted girth of the graph. This represents a nontrivial hurdle. Nevertheless, in this 
paper we show how to overcome this hurdle and obtain an 0{Mn u) ) time algorithm for undirected graphs with integer 
weights in [1, M\. This matches the runtime of the best APSP algorithm in such graphs: In a paper first presented at 
STOC'92, Seidel [5T] showed that APSP in undirected and unweighted n-node graphs can be solved in 0(n u ) time. 
In FOCS'99, Shoshan and Zwick [22] (following Galil and Margalit [12]) showed that APSP in undirected n-nodc 
graphs with integer edge weights in [0,M] can be solved in O(Mn^) time, thus extending Seidel's running time to 
weighted undirected graphs. 

Our results: reductions and algorithms. We develop our algorithms by first obtaining extremely efficient 
reductions from the minimum weight cycle problem to the minimum weight triangle problem which preserve the 
interval in which the weights lie, within a constant factor. 

Undirected graphs. For undirected graphs our results are as follows. 

Theorem 1. Let G(V, E,w) be an undirected graph with w : E — > {1, . . . , M} and let C be a minimum cycle in 
G. There is an 0(n 2 (\ognM) logn) time deterministic algorithm that computes a cycle C and constructs O(logn) 
graphs G[, . . . , G' k on Q(n) nodes and edge weights in {1, . . . , O(M)} such that either w(C) = w(C) or the minimum 
out of all weights of triangles in the graphs G^ is exactly w(C). 
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Since a minimum weight triangle in a graph with weights bounded by O(M) can be found via a single distance 
product computation in 0(Mn u ) time [2] [26] , we obtain the following corollary. 

Corollary 1. A minimum weight cycle in an n-node undirected graph with integer edge weights in [1,M\ can be 
found in 0(Mn UJ ) time. 

Directed graphs. Our reduction for undirected graphs relies on the fact that distances are symmetric. It is unlikely 
that it is possible to modify the reduction so that it works for directed graphs as well. Hence, for directed graphs 
new ideas are required. The reduction to minimum triangle is not as efficient, however, the resulting algorithm for 
minimum cycle in directed graphs has the same running time as the one for undirected graphs with nonnegative 
weights. Our approach for directed graphs can be combined with our approach for undirected graphs to yield an 
efficient algorithm also for mixed graphs, that is, graphs which contain both directed and undirected edges. The 
approach works, provided the weights of the mixed graph are nonnegative. 

When negative edge weights are allowed, a negative cycle may exist. Finding a minimum weight cycle when 
its weight is negative is an NP-hard problem, as it solves Hamiltonian cycle. When negative weights are allowed, 
the minimum cycle problem in the absence of negative cycles is in P for both directed and undirected graphs, but 
is NP-hard for mixed graphs [4]. Our techniques for directed graphs are strong enough to support negative edge 
weights within the same running time as when the weights are nonnegative. This is extremely interesting, as the 
typical way to reduce the general problem to the nonnegative weights problem involves computing node potentials 
(see e.g. [13]). These potentials however typically increase the magnitude of the weights to even il(Mn), which would 
be bad if our goal is to use algorithms that have exponential dependence on the bit representation of the weights, 
such as 0{Mn LO ). We circumvent the potential approach by focusing on the general problem directly. 

We obtain: 

Theorem 2. Let G(V, E,w) be a directed graph on n nodes, w : E {— M, ...,M}. In 0(Mn ul ) time one can 
construct O(logn) graphs G[, . . . , G' k on O(n) nodes and edge weights in {1, . . . , O(M)} so that the minimum out of 
all weights of triangles in the graphs G' i is exactly the weighted girth of G. 

Our results: equivalences. Vassilevska W. and Williams [53] showed that the minimum triangle and minimum 
cycle problems are equivalent, under subcubic reductions. Their reduction from minimum triangle to minimum cycle 
only increased the number of nodes and the size of the edge weights by a constant factor. However, their reduction 
from minimum cycle to minimum triangle was not tight; it only proved that an 0(n 3 ~ e ) algorithm for minimum 
triangle would imply an 0(n 3_e / 3 ) algorithm for minimum cycle. Our reductions, on the other hand, imply a much 
stronger equivalence between the two problems. This equivalence is especially strong for undirected graphs with 
integral weights from the range [1, M\. 

Corollary 2. If there is a T(n, M) time algorithm for the minimum cycle problem in undirected graphs with integral 
edge weights in [1,M], then there is a T(0(n), 0{M)) + 0{n 2 ) time algorithm for the minimum triangle problem in 
such graphs. Conversely, if there is a T(n, M) time algorithm for the minimum triangle problem in undirected graphs 
with integral edge weights in [1,M], then there is an 0(T(0(n), 0{M)) log n + n 2 logn log nM) time algorithm for 
the minimum cycle problem in such graphs. 

A natural question is whether the triangle problem is special. Do similar reductions exist between minimum cycle 
and minimum fc-cycle for constant k > 3? We answer this in the affirmative. 

Theorem 3. Let k be any fixed constant. Let G(V, E,w) be a graph on n nodes, w : E — >• {1, . . . , M}. One 
can construct O(logn) undirected graphs G[, . . . , G\ on O(fcn) nodes and edge weights in {1, . . . , 0(M )} so that the 
minimum out of all weights of k- cycles in the graphs G\ is exactly the weighted girth of G. Moreover, given the 
minimum weight k-cycle of the graphs G\, one can find a minimum weight cycle of G in 0(n) additional time. If G 
is directed, the reduction runs in 0(Mn UJ ) time, and if G is undirected, it runs in 0{n 2 log nM) time. 

Our results: approximation. Another approach to gain efficiency for problems with seemingly no subcubic 
time exact algorithms has been to develop fast approximation algorithms (see [27] [1] [7] in the context of shortest 
paths). Lundell and Lingas [T7] gave two approximation algorithms for the girth problem: an 0(n 15 ) time 8/3- 
approximation for undirected unweighted graphs, and an 0{n 2 (log n) log nM) time 2-approximation for undirected 
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graphs with integer weights in the range {1, . . . , M}. Very recently, Roditty and Tov [19] improved the approximation 
factor to 4/3-approximation for the weighted case while keeping the running time unchanged. Due to Zwick's [27] 
0(n"/e \og{M / e)) time (1 + ^-approximation for APSP and the simple reduction from minimum weight cycle in 
directed graphs to APSP, the girth of a directed graph admits an (1 + ^-approximation in 0(n" /e log(M/e)) time. 
Our reduction from Theorem [T] implies the same result for undirected graphs with nonnegative weights as well, 
following up on the work of Roditty and Tov from SODAT1 [19] . 

Theorem 4. There is an 0(n u /e \og(M/e)) time (1 + e)- approximation algorithm for the minimum cycle problem 
in undirected graphs with integral weights in [1,M]. 

2 Preliminaries 

Let G{V, E,w) be a weighted graph, where V is its set of vertices or nodes (we use these terms interchangeably), 
E C V x V is its set of edges, and w : E — >• {1, . . . , M} is a weight function. The function w(-, ■) can be extended 
to the entire V x V by setting w(u, v) — oo for every (u, v) ^ E. Unless otherwise noted, n refers to the number of 
nodes in the graph. 

An edge can be directed or undirected. An undirected graph is a graph with undirected edges only and a directed 
graph is a graph with directed edges only. A mixed graph is a graph that may have both directed and undirected 
edges. All graphs considered in this paper are simple. A graph is simple if it does not contain self loops or multiple 
copies of the same edge. In a simple mixed graph, a node pair x, y cannot be connected by both a directed and an 
undirected edge. In both directed and mixed simple graphs, two directed edges (x, y) and (y, x) in opposite directions 
are allowed since they are considered distinct. 

We define a cycle C in a graph G(V, E, w) to be an ordered set of vertices {vi,V2, ■ ■ ■ , v?}, such that (vi, Uj+i) G E 
for every i < £ and (vg,vi) G E. Let w(C) be the sum of the weights of the edges of C and let w max (C) be the 
weight of the heaviest edge. We denote with dc[vi,Vj] the weight of the path that traverses the cycle from Vi to Vj 
by passing from Vi to Vi + i and so on. In the case that j < i we traverse from vi to v\ and continue until we reach Vi. 
Let n(C) denote the number of vertices/edges in C. A cycle C is simple if no node or edge appears twice in C . With 
this definition, an undirected graph cannot have a simple cycle on 2 nodes, where as directed and mixed graphs can, 
provided the two cycle edges are in opposite directions and hence distinct. 

3 Our approach 

Our reductions are based on a combinatorial property of cycles in weighted directed, undirected and mixed graphs 
that might be of independent interest. This property is extremely useful as it shows that crucial portions of the 
minimum weight cycle are shortest paths. We present this property in the following lemma. 

Lemma 1 (Critical edge). Let G(V, E, w) be a weighted graph, where w : E —> R ; and assume that G does not contain 
a negative cycle. Let C — {v\, t>2, ■ ■ ■ , v?} be a cycle in G of weight w{C) > and let s G C. There exists an edge 
(vi,v i+ i) on C such that \w(C)/2] -w(vi,v i+ i) < d c [s,Vi] < [w(C)/2\ and \w(C)/2] -w(vi,v i+ i) < dc[vi+i,s] < 
[w(C)/2\. Furthermore, if C is a minimum weight cycle in G then d[s,Vi] = dc[s,Vi] and d[vi+i,s] = dc[vi+i,s\. 

Proof. We can assume, wlog, that s — v\. We start to traverse along C from v\ until we reach the first edge (vi, Uj+i) 
that satisfies dc[vi,vi\ < [w(C)/2\ and dc[v\,Vj\ + w(vi,v i+1 ) > \w(C)/2~\. Since dc[vi,v\\ = < [w(C)/2\ either 
we find an edge (vi, that satisfies the requirement, where i < £ or we reach vi without finding such an edge. In 
the latter case dc[vi,vt] < \ w{C)/2\ and since dc[vi,ve] +w(vg,vi) — w(C) > \w(C)/2~\ the edge (v(,vi) satisfies 
the requirement. 

It follows immediately from the properties of the edge (i>i,Vi+i) that dc[vi,Vi] > \w(C)/2~\ — w(vi,Vi+i) and 
hence we get that \w(C)/2~\ — w(vi,v i+1 ) < dc[vi,Vi] < \w{C)/2\ as required. 

We now bound dcffj+i, V\\. We know that dc[vi+i> vi] = w(C) — (dc[vi,Vi) + w(vi,Vi + i)). Since dc[vi,Vi] + 
w(vi,Vi+i) > \w(C)/2~\ we get that dc[vi + \,vi] < \w(C)/2\. Also, since dc[vi,Vi] < [w(C)/2\ we get that 
dc[vi+i,vt] > \w(C)/2] -w(vi,v i+1 ). 
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It remains to show that if C is a minimum weight cycle, then d[«x, Vi] = dc[v\,Vi\ and d[vi+i,vi] — dc[v%+ii Vil- 
li G is a directed graph, then it is straightforward to see that the minimality of C implies that dc[u,v] = d[u,v] 
for every u,v £ C and in particular d[vi,Vi] = dc[v\,Vi] and d[vi+\, v{\ = dc[vi+i,vi] as required. Thus, we 
only need to consider the case that G is an undirected graph. From the first part of the proof we know that 
dc[vi+i,v{\ < [w(C)/2\. If d[vi + i,v{\ < dc[vi+i,vi], then let P be the path from Vi + i to v\ of weight d[vi+i,vi] 
and let C2 be the portion of C from v\ to Uj+x- The union of P and C2 is a walk in G whose weight is strictly less 
than w(C). Furthermore, since d[vi+i,vi] < dc[vi+i,vi] < [w(C)/2\ < w(C2), P and C2 must differ by at least one 
edge and hence P U C2 contains some simple cycle of weight less than w(C), a contradiction to the minimality of C. 
The argument for showing that d[v\,Vi] — dc[vi,Vi] is symmetric. □ 

Lemma [T] shows that it is possible to decompose every cycle into three portions: a single edge of weight at most 
0(M) and two pieces whose weight differs by at most O(M), and which are shortest paths if the cycle is of minimum 
weight. This observation is crucial for our efficient reductions. Another important piece of Lemma [T] is that every 
vertex on the cycle has a critical edge. This is especially important in the directed graph case. 

Armed with Lemma [1] we can describe the general framework of our approach. Suppose that we have some way 
to compute a function D : V x V —> M that satisfies: 

• For every u, v £ V, d[u, v] < D[u, v] 

• There exists a vertex v on the minimum cycle C whose critical edge (x,y) endpoints satisfy 15 [v, a;] = d[u,a;] 
and D[y,v] = d[y,v]. 

In Section [4] we show how to compute a function D in 0(n 2 log n log Mn) time for undirected graphs with integral 
weights from [1,M], and in Section [5] we show how to compute a function D in 0{Mn ul ) time for directed graphs 
with integral weights from [-M, M] and no negative cycles. 

Now consider the following (multi-)graph G'(V, E', w') where V — V 1 U V 2 and V 1 , V 2 are disjoint copies of V. 
For every D[a, b] which was computed we place an edge between a 1 £ V 1 and b 2 £ V 2 and (for directed graphs) also 
one between a 2 £ V 2 and b 1 £ V 1 . These edges get weight D[a, b] and correspond to the two large portions of the 
minimum cycle. Further, for every edge (a, b) in G, we add an edge from a 2 E V 2 to b 2 £ V 2 with weight w(a,b), 
i.e. V 2 induces a copy of G; these edges correspond to the critical edge of the minimum cycle. In our reduction for 
directed graphs we further transform G' into a simple undirected tripartite graph. 

Consider v,x,y from the second bullet above. By Lemma U £>[i!,x] + w(x,y) + D[y,v] — dc(v,x) + w(x,y) + 
dc{y,v) = w(C). Hence G' will contain {t; 1 , x 2 , y 2 } as a triangle of weight w(C). Our reductions in the next two 
sections give transformations which ensure that every triangle in G' corresponds to a simple cycle in G and that 
{v 1 , x 2 , y 2 } is preserved as a triangle. Since the values D[-,-\ are upper bounds on the distances, {v 1 , x 2 , y 2 } is a 
minimum weight triangle in G' . The graph G' however can have really large weights; D[-,-] can be as large as Mn 
in general. Thus our transformations also apply a weight reduction technique which reduces all edge weights to the 
interval [— O(M), O(M)]. This technique is different for undirected and directed graphs. 

Finding a minimum cycle. Our reductions show that the minimum cycle problem can be efficiently reduced to 
the minimum triangle problem in a different graph with roughly the same number of nodes and weight sizes. Here 
we briefly discuss how one can actually find a minimum weight triangle in an n-node graph G(V, E, w) with integral 
edge weights in the interval [— M, M]. With our reductions, this will give algorithms for the minimum cycle problem 
as well. 

Let A be the nxn adjacency matrix of G defined as A[i, j] = w(i,j) whenever [i, j) £ E and A[i, j] — 00 otherwise. 
A well known approach to finding a minimum weight triangle mimics Itai and Rodeh's algorithm for unweighted 
triangle finding [14]. It first computes the distance product of A with itself, (A* A)[i,j] = mink A[i,k] + A[k,j], to 
find for every pair of nodes i,j the minimum length of a path with at most 2 edges between them. Then, the weight 
of a minimum triangle is exactly 

rain A\j, i] + (A*A)[i,j]. 

Finding the actual triangle takes only 0{n) time after one finds i,j minimizing the above expression. Thus the 
running time is dominated by the time required for computing A* A. The algorithm of Alon, Galil and Margalit [2] 
(following Yuval [26]) does this in 0(Mn u ) time, whenever the entries of A are integers in [—M,M]. Hence a 
minimum triangle, can be found in 0{Mn u} ) time. 
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Algorithm 1: Min-Cycle(G, t) 



Algorithm 3: Controlled-Relax(w, w u ) 



foreach s E V do 

C <- Cycle?(G,s,2r); 
_ if w(C') < w{C*) then C* <- C 
return C* 

Algorithm 2: Cycle?(G, s, T) 

foreach v G V do d[v] oo; 
d[s] =0; 

Q <-{*>! 
while Q ^ do 

u <— Extract-Min(Q); 

Controlled- Relax(u, t'/2); 



4 Minimum weight cycle in undirected graphs with weights in {1, ... , M} 

Let G(V, E, w) be an undirected graph with integral edge weights from the range [1, M}. In this section we show that 
in 0(n 2 log Mn) time we can compute a cycle whose weight is at most twice the weight of the minimum weight cycle 
and a new undirected graph G'(V , E' , w') with integral weights from the range [-M, M] whose minimum triangle if 
exists corresponds to the minimum weight cycle in G, with constant probability. (To boost the probability of success, 
we actually create O(logn) graphs G' .) If G' does not have a triangle then the cycle that we have computed is the 
minimum weight cycle of G. We start by presenting an 0(n 2 ) time algorithm that given an integer t either reports 
a cycle of length 2t or computes all distances up to t. The computed distances are used to form the graph G'. 

Cycle or Distance Computation. The algorithm works in iterations and in each iteration it repeats the same 
procedure from a new vertex of the graph. This procedure is a simple adaptation of Dijkstra's algorithm. The input 
in each iteration is a source vertex s and an integer value t. The algorithm either reports a cycle of length at most 
2t or computes the distances from s to every vertex that is within distance t from s. Lingas and Lundell [T7] used 
a similar approach in order to compute a 2-approximation of the minimum weight cycle. Their algorithm, however, 
either returns a cycle of length at most 2t or computes the distances from s to every vertex that is within distance 
2t from s. This small difference between the two algorithms is crucial for our needs. The algorithm is given in 
Algorithm [TJ The running time of the algorithm is 0(n 2 logn). The algorithm repeats the procedure Cycle? n times, 
each time with a different vertex. Every run of Cycle? takes at most O(nlogn) time since it stops with the first 
cycle it detects. 

In the next Lemma we prove an important property of the algorithm. 

Lemma 2. For any integer t, Min-Cycle(G,t) either finds a cycle of weight at most 2t, or computes all distances of 
length at most t. 

Proof. A cycle is reported when a vertex u is extracted from the priority queue Q and for one of its edges (it, v) that 
is being relaxed the value of d[v] before the relaxation is not infinity. As any distance and any distance estimation 
are at most t, if a cycle is reported it must be of length at most 2t. If a cycle is not reported, then our algorithm is 
almost identical to Dijkstra's algorithm. The only difference is that our algorithm relaxes an edge (it, v) when u is 
extracted from the priority queue if and only if d[u] + w(u, v) < t, while Dijkstra's algorithm relaxes all edges of u 
with no restriction. This implies that our algorithm computes all distances that are smaller or equal t. □ 



The reduction to minimum triangle. Our goal is to prove Theorem[T] The main part of the proof is describing 
an algorithm that computes an upper bound for the minimum weight cycle and an instance G' of minimum triangle, 
such that either the girth of the graph is exactly the upper bound, or with constant probability the minimum triangle 
weight in G' is the girth of G. Below we only present G' as having large weights. Later on, we find a value t with 
which we use Lemma O so that 2t is a bound on the minimum cycle weight that is tight within O(M). As mentioned 
in Section[3l this value allows us to reduce the weights of G' so that they fall in the interval [-O(M), 0(M)]. 



(u,v) <— Extract-Min(Q u ); 
while d[u] + w(u, v) < w u do 
if d[v] 7^ oo then 
| report a cycle and stop; 
else 
I Relax(u, v); 

(u,v) <— Extract-Min(<3„); 



t t + l w(C) 

Figure 1: In the gray area Min-Cycle reports a cycle. 
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Reminder of Theorem [T] Let G(V, E, w) be an undirected graph with w : E — > {1, . . . , M} and let C be a minimum 
cycle in G. There is an 0(n 2 (log nM) log n) time deterministic algorithm that computes a cycle C and constructs 
O(logn) graphs G' 1; . . . , G' k on O(n) nodes and edge weights in {1, . . . , O(M)} such that either w(C) — w(C) or the 
minimum out of all weights of triangles in the graphs G[ is exactly w(C). 

The weight of the minimum cycle is an integer value from the range [l,nAf]. From Lemma [5] it follows that we 
can use algorithm Min-Cycle to perform a binary search over this range in order to find the largest value t € [1, nM] 
for which Min-Cycle(G, t) does not report a cycle but computes all distances of length at most t (see Figure [IJ. This 
implies that by running Min-Cycle (G, t + 1) we obtain a cycle of weight at most 2t + 2. Hence, we only need to show 
that it is possible to detect the minimum cycle in the case that its weight w(C) is 2t + 1 or less. Let us first prove 
some consequences of the fact that Min-Cycle(G, t) does not report a cycle. 

Lemma 3. Let C — {vi, i>2, . . . , vi} be a minimum cycle in G{V, E, w). Suppose that Min-Cycle(G, t) does not report 
a cycle. There are three distinct vertices Vi,Vi+i,Vj € C such that dc[vj, Vi] + w(vi, i>i+i) > t and dc[vi+i,Vj] + 
w(vi,v i+1 ) > t. 

Proof. Let (vi,Vi+i) be the critical edge for v\ given by Lemma [TJ Assume first that v% ^ Vi and v\ ^ wj+i. If 
either dc[vi,Vi] + w(vi, < t or dc[vi+i,vi] + w(v%, w-t+i) < t then the edge tu(t>t,u<+i) is relaxed. Assume that 
we are in the case that dc[v%,Vi] + w(vi,Vi+\) < t. Then after (vi,Vi+x) is relaxed < t. If < oo 

before the relaxation of (vi,Vi+x) the algorithm stops and reports a cycle. If = oo before the relaxation of 

(Vi,Vi-\-i) then a cycle will be detected as well but only when the edge (1^+2,^1+1) is relaxed. This edge must be 
relaxed since dc[Vi+i> Vi] < l w {G)/2\ < t which implies that w.j +2 will be extracted and its edge («i+2> will 
satisfy the relaxation requirement and will be relaxed. We conclude that if either dc[vi,Vi] + w{vi,Vi + i) < t or 
dc[i>i+i, V\] + w(vi,Vi+i) < t then Min-Cycle(G, t) must report a cycle, giving a contradiction. 

We now turn to the case that either v\ = Vi or v\ — Uj+i. Assume wlog that v\ = Vi, that is, (vi, = (vi, Vz)- 
From Lemma[T]we know that w{vi,v^) > \w(C)/2] and dc[v2,vi] < [w(C)/2\. We also know that there is at least 
one additional vertex vi between v 2 an d vi on the cycle C. We now apply Lemma [T] on the vertex vg. It is easy to 
see that in that case the edge (vi, V2) will be the critical edge of vi as well. We now have three different vertices and 
the rest of this case is identical to the first case. □ 

As a first attempt, we create the new graph G'(V, E', w') as follows. The vertex set V contains two copies V 1 
and V 2 of V. For £ = 1,2, let E l be the set of edges with both endpoints in V % . The set E 1 is empty and the set E 2 
is E, that is, (u 2 ,v 2 ) € E 2 if and only if (u,v) E E. Let E 12 be the set of edges with one endpoint in V 1 and one 
endpoint in V 2 . Let u 1 £ V 1 and v 2 £ V 2 . If the distance between u and v was computed by Min-Cycle(G, t) then 
we add an edge (it 1 , v 2 ) to E 12 with weight d[u, v]. We show that there is triangle in G'(V, E', w') that corresponds 
to the minimum cycle of G and has the same weight. 

Claim 5. Let C = {vi, V2, ■ ■ • , vi} be a minimum cycle in G(V, E, w). Assume that w(C) < 2t + 1. There exists a 
triangle in G'(V',E',w') on vertices of C of weight w(C). 

Proof. Without loss of generality, let v\ be the vertex Vj from Lemma [31 and let Vi and Uj+i be the other two 
vertices. From Lemma [3] we know that all three vertices are distinct and that dc[vi,vi\ + w(vi,Vi + i) > t and 
dc[vi+i,v{\ + w(vi,Vi + i) > t. Combining this with the fact that G is a minimum cycle and w(C) < 2t + 1 we get 
that d[i>i,Ui] = dc[vi,Vi] < t and d[vi+i,v{\ = dc[vi+x, v%] < t. When Cycle? is run from v\ it computes 
and d[vi,v i+ i]. Hence, there must be a triangle of weight w(C) in G' on the vertices v\,v 2 and vf +1 . □ 

The claim above shows only one direction, that is, if there is a minimum cycle G of weight at most 2t + 1 in 
G then there is a corresponding triangle in G' on vertices y 2 ,z 2 € V 2 and x 1 £ V 1 , that correspond to vertices 
of C with the same weight. This situation is depicted in Figure Ufa). To complete the reduction we must show 
that there are no false positives: triangles in G' of smaller weight which do not correspond to a minimum cycle of 
G. Unfortunately, this is not the case and G' may have such false triangles with smaller weight. This situation is 
depicted in Figure 0Jb). Let x,y,z £ V. If there is a shortest path of length at most t from x to z whose last edge 
is (y, z) then there is a triangle in G'. To see that notice that there are two different shortest paths one from x to z 
and one from x to y, both of length at most t. In such a case the graph G' includes the edges (a; 1 , y 2 ) and (x 1 , z 2 ) 
and together with the edge (y 2 ,z 2 ) they form a triangle. Moreover, such a triangle has the same structure as a 
valid triangle and might be of smaller weight, thus, a triangle detection algorithm cannot distinguish between a valid 
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Figure 2: (a) A minimum cycle in G that is transformed into a triangle in C . (b) A simple path in G that is 
transformed into a triangle in G' . 

triangle and a false triangle. In what follows we first show that this is the only situation in which a false triangle is 
formed and then we show a construction that avoids such false triangles. 

In the above pathological case the only reason that the triangle x 1 ,?/ 2 ,^ 2 did not correspond to a cycle, was 
because we had two different paths Pi and Pi that both start in the same vertex and the last vertex of one of these 
paths was the vertex right before the last vertex of the other path. In the next lemma we show that this is the only 
bad case. 

Lemma 4. Let x,y,z^V be three distinct vertices. Let Pi = y — > y' — > . . . — > x and P2 — x —> . . . — > z' — > z be 
simple shortest paths between y and x and x and z respectively. Let y' ^ z and z' ^ y and let (z,y) 6 E. Then, 
Pi U Pi U {(z, y)} contains a simple cycle of weight at most w(Pi) + w(P 2 ) + w(z, y). 

Proof. Let P x be Pi with its edges reversed. Look at P^ 1 and P2. There are two options. Either one path is a 
subpath of the other, or there is a node x' such that x — ► . . . — » x 1 is a subpath of both, and x' is followed by qi in 
Pf and by q 2 ^ qi in P 2 . 

Consider the first case. Wlog, Pi is a subpath of P x (the other inclusion is symmetric). Since y' ^ z, the 
subpath between y and z on Pi has at least 2 edges, and adding edge (z,y) produces a simple cycle of weight less 
than the sum of the two original path weights. 

Consider the second case when x' , q%, qi exist as above. If there is some node between x' and y on PT 1 which also 
appears in Pi after x', then let q be the first such node. Then no node on Pi between x' and q appears between x' 
and q in P^ 1 . The two disjoint simple paths between x' and q form a simple cycle on at least 3 nodes since qi 7^ qi. 
The weight of this cycle is less than the sum of the two original path weights. 

Finally, suppose no such q exists. Then the subpaths of P^ 1 and Pi between x' and y and x' and z share no 
vertices and hence adding edge (z, y) closes a simple cycle of weight at most w(Pi) + w(Pi) + w(z, y). □ 

Lemma U implies that our reduction to minimum triangle will work, provided that we can ensure that for every 
triangle x 1 , y 2 , z 2 in G", the last node z' before z on the shortest path from x to z in G is distinct from y. To do this, we 
use the color-coding method from the seminal paper of Alon, Yuster and Zwick [3]. The idea is as follows. Let {Ci, Ci} 
be two distinct colors and suppose we assign to every node of G one of these colors independently and uniformly at 
random. Fix four vertices y, y', z, z'. The probability that color(y') = color(z') = Ci and color(y) = color(z) = Ci is 



Now we will modify G'(V, E', w') from before. Recall that V' — V 1 U V 2 . For every node x of G we add a copy 
x 1 to V 1 , so that V 1 is a copy of V. Furthermore, if color(a;) = Ci we also add a copy x 2 to V 2 . We now define 
the set of edges E' . Let E^ be the set of edges between V 1 and , for i,j 6 {1, 2}. The edge set E 11 is empty, so 
E' = E 12 U P 22 . Let x, z',z € V such that (z', z) is the last edge of the shortest path from x to z. The sets P 12 and 
P 22 are defined as follows: 



The weight of an edge (x 1 , z 2 ) £ P 12 is d[x, z]. The weight of an edge (x 2 , z 2 ) G P 22 is w(x, z). We now prove 
that G' does not contain false triangles. 



1/2 4 



0(1). 



P 12 = {{x\z 2 ) I color(z') = Ci A color(z) = C 2 } 



P 22 = {{x 2 ,z 2 ) I color(a;) = C 2 A color(z) = C 2 }. 



7 



Lemma 5. If T = {x, y, z} is triangle in G' then there exists a simple cycle C in G such that {x,y, z} C C and 
w(C) < w(T). 

Proof. Any triangle in G' either have one vertex from V 1 and two vertices from V 2 or all three vertices from V 2 . In 
the latter case the triangle is also in G so we focus in the former case, that is, T — {x 1 ,y 2 , z 2 } is a triangle in G' 
such that a; 1 G V 1 and y 2 , z 2 G V 2 . Let x, y, z G V be the vertices that correspond to x 1 , y 2 and z 2 in G. Let y' (z 1 ) 
be the last vertex before y (z) on the shortest path Pi (P2) between x and y (z) in G. The fact that (a; 1 ,?/ 2 ) G E 12 
and (a; 1 ,^ 2 ) G P 12 implies that color(y') = color(z') = C\ and color(i/) = color(z) = C2. Hence we get that y' ^ z 
and z' ^ y. Combining this with the fact that E 22 C E we get that the paths Pi, P2 and the edge (y, z) satisfy the 
requirements of Lemma[4j and there is a simple cycle of weight at most w(Pi) + w{P2) + w(y, z) = w(T) in G. □ 

Now that we have shown that G' does not contain false triangles we prove that the minimum weight cycle in G 
corresponds to a triangle in G' . (This can be viewed as proving Claim [5] for the new construction of G"). 

Claim 6. Let C = {v\, V2, • ■ • , vi\ be a minimum cycle in G(V, E, w). Assume that w{C) < 2t + 1. Then there exists 
a triangle in G' (V , E' ,w') on vertices of C of weight w{C), with constant probability. 

Proof. Without loss of generality, let vi be the vertex Vj from Lcmma[3J and let Vi and Vi + i be the other two vertices. 
As in the proof of Claim[Sl d[v\,Vj\ — dc[v\,Vj\ < t and d[v i+ i,vi] — dc[vi+i, Vi) < t and these values are computed 
by Min-Cycle(G, t) . The random coloring is successful when color(w i _ 1 ) = C±, color(u,-) = C 2 , color(w i+1 ) = C 2 and 
color(wi + 2) = C\. The probability that this happens is I/2 4 = 0(1). The triangle {v\, vf, v 2 +1 } is in G' exactly when 
the coloring is successful, and hence C is represented by that triangle in G' with constant probability. The weight of 
the triangle {v{,vf, vf +1 } is d[vi,Vi] + w(vi,v l+1 ) + d[v i+ i,Vi] = w(C). □ 

Weight reduction. Currently, the maximum edge weight in G' can be as large as f2(nM) as the weights of edges 
in E 12 are distances in G. To complete the reduction, we show that it is possible to reweight the edges of G 1 without 
changing the minimum triangle so that the edge weights will be integers from the range [—M,M]. 

The key idea is to use Lemma |3] in two different ways. As we previously mentioned, Lemma |3] implies that 
dc[vj,Vi] < t and dc[vi+i,Vj] <t. Moreover, the bounds dc[vj, Vi] +w(vi, fi+i) > t and dc[v%+i, Vj] +w(vi, Vi+i) >t 
imply that dc[vj,vi\ > t — M and dc[vi+i,Vj] > t — M . Thus, we can remove from E 12 every edge of weight strictly 
more than t and every edge of weight t-Mor smaller with no effect on the minimum triangle in G 1 . We now 
decrease the weights of all the edges that were left in E 12 by t. The weight of every triangle in G 1 with a node from 
V 1 has decreased by exactly It. Hence, the minimum triangle out of those with a node in V 1 remains the same. 
The weights of edges in E 12 are now integers from the interval [— M, 0], and the rest of the edge weights are still in 
[1, M], If the minimum weight triangle in G' now has nodes only from V 2 , then this triangle was also the minimum 
weight one in G' before the reweighting, and hence corresponds to a minimum weight cycle, with high probability. 
Otherwise, the minimum weight triangle in G' has a node from V . The minimum out of these triangles was also 
the minimum one among the triangles with a node in V 1 also before the reweighting. Hence it also corresponds to 
a minimum weight cycle, with high probability. This completes the description of our construction. 

Derandomization. The reduction can be made deterministic, just as in the color-coding paper of Alon et al. 
[3], by using a fc-perfect hash family, a family F = {fi, . . . , f\F\} of hash functions from {1, . . . , n} to {1, . . . , k} so 
that for every V' C V with \V'\ = k, there exists some i so that fi maps the elements of V to distinct colors. In 
our case, k — 2. By enumerating through the functions of F, and using each fi in place of the random coloring, 
our reduction runs in 0(n 2 (logr7,M) logn + |P|n. 2 ) time, provided each fi can be evaluated in constant time. Our 
reduction produces 0(|P|) instances of minimum triangle. 

Schmidt and Siegel [20] (following Fredman, Komlos and Szemeredi [9]) gave an explicit construction of a fc-perfect 
family in which each function is specified using O(k) + 2 log log n bits. For our case of k = 2, the size of the family 
is therefore 0(log 2 n). The value of each one of the hash functions on each specified element of V can be evaluated 
in O(l) time. Alon, Yuster and Zwick [3], reduced the size of the hash family to O(logn). Using this family we can 
derandomize our reduction so that it runs in deterministic 0(n 2 (\ognM) logn) time. 
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5 Minimum cycle in directed graphs with weights in {— M, . . . , M} 



In this section we consider directed graphs graphs with possibly negative weights but no negative cycles. In contrast 
to the situation in undirected graphs it is relatively easy to reduce the minimum cycle problem in directed graphs to 
the problem of computing all pairs shortest paths. If D is the distance matrix of a directed graph then its minimum 
cycle has weight mhijj D[i,j] + w(j,i). Hence, using Zwick's APSP algorithm [27] we can compute the minimum 
cycle in O(M ' 681 n 2 ' 575 ) time. In this section we show that the minimum cycle problem in directed graphs can be 
reduced to the problem of finding a minimum triangle in an undirected graph. This also implies that the minimum 
weight cycle in directed graphs can be computed in 0(Mn u ) time. 

Similarly to before, our approach will be to compute upper bounds on the distances in the graph so that for some 
node s on the minimum cycle C and its critical edge (vi,v i+1 ) we obtain the exact distances d[s,Vi] — dc[s,Vi] and 
d[v i+ i, s] = d c [v i+1 , s]. 

Computing cycle distances. The Dijkstra-like approach in the previous section does not work for directed 
graphs. It also only applies when the edge weights are nonnegative. Here we utilize a new approach that allows us to 
reduce the minimum cycle problem in directed graphs with integral weights in the interval \—M, M] to the minimum 
triangle problem in undirected graphs with weights in [— M, M]. Our result is more general than before. However 
this comes at a cost: the reduction no longer takes nearly quadratic time, but consumes 0(Mn LJ ) time. 

Our approach uses the fact that Lemma Q] applies for every vertex of a cycle, together with a result by Yuster 
and Zwick [25] obtained by a clever modification of Zwick's APSP algorithm [27] given in Theorem [7] below. 

Theorem 7 (Yuster and Zwick '05). Given an n-node directed graph with integral edge weights in the interval 
[-M, M], in 0(Mn u ) time one can compute an n x n matrix D such that the i,j entry of the distance product D* D 
contains the distance between i and j . 

The matrix D can contain entries with values as large as Q,(Mn) and so D ★ D is not known to be computable 
in truly subcubic time, even when M is small. Nevertheless, the theorem applies to general graphs with positive or 
negative weights. It also gives an 0{Mn u ) time algorithm for detecting a negative cycle in a graph, and is extremely 
useful in computing minimum cycles. 

The Yuster-Zwick algorithm proceeds in stages. In each stage I, a node subset sample Be is maintained so that 
each node is in Be with probability at least min{l, 9(2/3)^ Inn}. They prove the following lemma. 

Lemma 6 (Yuster and Zwick '05). For every stage t and any node s £ Bi and node v s V, the algorithm has 
estimates D[s, v] and D[v, s], so that if the shortest path from s to v has at most (3/2) f edges then D[s, v] = d[s, v], 
with high probability. Similarly, if the shortest path from v to s has at most (3/2) f edges then D[v,s] = d[v, s] with 
high probability. 

The Yuster-Zwick algorithm also provides an additional matrix n of predecessors so that if k = n[i,j], then k is 
the predecessor of j on a simple path from i to j of weight D[i,j]. Similarly, one can obtain a matrix n' of successors 
so that if k = H'[i,j], then k is the successor of i on a simple path from i to j of weight D[i,j]. 

Now, first use the algorithm to check whether the given graph has a negative cycle. If it does not, then let C be 
the minimum weight cycle, w(C) > 0. Recall that n(C) is the number of vertices/edges on C. Let £ be the minimum 
value so that n{C) < (3/2) e . Note that then n{C) > (3/2) ^ The probability that a particular node s of C is not 
in Bi is at most 1 — (2/3) (9 Inn). The events are independent for all s in C, and so the probability that no node of 
C is in Bp is at most 

(1 - (2/3) £ (91nn))"( c ) < (1 - (2/3) £ (9 Lnn))< a / 2 >' _1 < 1/n 6 . 

Thus the probability that some node s of C is in Be is 1 — poly~ 1 (n); furthermore by Lemma [6] (with high 
probability) for all i£C, the Yuster-Zwick algorithm has computed D[s, x] = d[s, x] and D[x, s] = d[x, s], since the 
number of edges on the respective shortest paths are at most n(C) < (3/2)^. 

In particular, this means that D[s, Vi] = d[s,Vi] and Z?[i>i+i,s] = d[vi+\, s] for the critical edge (vi,Vi+x) for s 
on C as Lemma Q] applies for every vertex of C. Moreover, since C is a minimum weight cycle with w{C) > 0, by 
Lemma [1] the paths between s and Vi and Vi+i and s on C are shortest paths between s and Vi and Vi+x and s, 
respectively. Hence, dc[s,Vi] = d[s,Vi] = D[s,Vi] and dc [v i+i , s] = d[vi+i,s] = D[vi-\-x, s], with high probability. 
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Creating the minimum triangle instance G' . G' will still be undirected, but unlike the construction for 
undirected graphs, G' will now be tripartite. The vertex set V of G' has partitions V 1 , V 2 , V 3 which are all copies 
oiV. 

The construction is as follows. For every directed edge (u, v) of G, add an edge from u 2 6 V 2 to v 3 G V 3 with 
weight w(u, v). Furthermore, for every two nodes x, y so that D[x, y] < oo add an edge from x 1 £ V 1 to y 2 G V 2 and 
one from x 3 G V 3 to y 1 eF 1 , each with weight D[x,y}. Hence the edges between x 1 G V 1 and y 2 G y 2 correspond 
to directed paths from x to y, and the edges between x 3 G y 3 and y 1 G y 1 correspond to directed paths from y to x. 
Hence any triangle in G' corresponds to a directed closed walk in G. However, any such closed walk must contain a 
simple cycle of no larger weight: If the walk is not simple, find a closest pair of copies of a node v on the walk. These 
copies enclose a simple cycle C" in G. Now, either C" has no larger weight than the walk, or removing it from the 
walk produces a smaller closed walk of negative weight, and hence G contains a negative cycle, which we assumed is 
not the case. Since G' contains no false positives, the minimum triangle of G' corresponds exactly to C. 

Weight reduction. As in the construction for undirected graphs, the maximum edge weight in G' can be as large 
as f2(nM). Here we give a different way to reduce them to the interval [—M,M]. 

Let t be a parameter which we will be changing. Intuitively, our goal will be to set t to something roughly 
[w(C)/2\; for our purposes, it will be sufficient for t to be < \w{C)/2\. 

Initially, t — Mn. Now, check whether there is a triangle a 1 G V 1 , b 2 G V 2 , c 3 G V 3 in G' so that 
D[a} , b 2 ], D[c 3 , a 1 ] < t. We run a binary search on t in the interval [0,Mn], until we find the smallest t such 
that there is such a triangle. Each search can be done using Boolean matrix product: create a matrix A which 
is 1 wherever D is < t and otherwise; multiply A by itself and check for a triangle closed by an edge (6 2 ,c 3 ), 
b 2 G V 2 .c 3 G V 3 . This takes <3(n w logw(C)) time. 

Let (whp) {s 1 , v 2 , vf +1 } be the triangle in G' that corresponds to the minimum cycle C of G. Since {s 1 , v 2 , v 3 +1 } 
is a valid triangle, and dc[s, «»], dc[vi+i, s] < [w(C)/2\ by Lemma[TJ then after the completion of the binary search, 
t < [w{C)/2\. Furthermore, since C is a minimum cycle and by the definition of t, w(C) < 2t + w(e), where e is 
some edge in G, which implies that w{C) <2t + M. Hence, t < [w{C)/2\ and w(C)/2 <t + M/2. 

Now, take G' and remove every edge (c 3 , a 1 ) G V 3 x V 1 with D[c 3 , a 1 } > t + M/2 and every (a 1 , b 2 ) G V 1 x V 2 
with D[a},b 2 ] > t + M/2. If an edge has weight < [w(C)/2] < t + M/2, it is not removed. In particular, (s 1 , v 2 ) 
and (v 3 +1 ,s 1 ) are still edges, by Lemma [1] 

Remove every (c^a 1 ) G V 3 x V 1 with D^a 1 ] <t—M and every (a 1 ,b 2 ) G V 1 x V 2 with ^[a 1 ,^ 2 ] <t- M. 
If an edge has weight > [w(C)/2\ — M > t — M, then it is not removed. Hence again (s 1 , v 2 ) and (v 3 +1 , s 1 ) are not 
removed because their weight is at least t — M as follows from Lemma [T] 

All remaining edges in (V 3 x V 1 ) U (V 1 x V 2 ) have integral weights in [t — M, t + M/2] , and C is still represented 
by the minimum triangle {s 1 , vf , v 3 +1 } . Now, for every remaining edge (a,b) G (V 1 x V 2 ) U (V 3 x V^ 1 ), change its 
weight to D[a, b] — t. The weights of the edges of G' are now in the interval [— M, M]. Furthermore, since the weights 
of all triangles have decreased by 2t, the minimum triangle of G' is still the same. This completes the construction 
of G'. 

Derandomization. The only randomized part of our reduction is our use of Yuster and Zwick's result. Their 
algorithm can be derandomized, as pointed out in their paper |25j without affecting our use of their result. Hence, 
we obtain a deterministic reduction from minimum cycle in directed graphs to minimum triangle in undirected graphs 
which runs in 0(M n u log n + n u (log Mn) log n) time and does not increase the size of the graph or the edge weights 
by more than a constant factor. 

6 Discussion 

We have obtained separate algorithms for minimum cycle for undirected graphs with nonnegative weights and for 
directed graphs with possibly negative weights. A natural question is whether one can obtain an algorithm that 
works for both types of graphs, or more generally for mixed graphs: graphs with both directed and undirected edges. 
This turns out to be possible for mixed graphs with nonnegative weights. (The problem is NP-hard for mixed graphs 
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with positive and negative weights, even when there are no negative cycles.) The idea for the proof of Theorem [5] 
below is to compute the distance estimates D[-,-) using the approach from our reduction for directed graphs. This is 
possible since when the weights are nonnegative, one can reduce the shortest paths problem in undirected or mixed 
graphs to that in directed graphs by replacing each undirected edge (u, v) by the two directed edges (u, v) and (v, u). 
Then the entire approach from the previous section applies up until the triangle instance needs to be constructed. To 
construct the triangle instance, we use the color-coding technique from our minimum cycle algorithm for undirected 
graphs, but only on the undirected edges. The derandomization also follows from the previous two sections. More 
details follow. 

Just as in the construction for directed graphs, for every directed edge (u, v) of G, add an edge from u 2 E V 2 
to v E V 3 with weight w(u, v). As in the construction for undirected graphs, randomly assign every node of G one 
of two different colors {C\,C-i\ independently uniformly at random. For every undirected edge (u, v) of G, add an 
edge from u 2 E V 2 to u 3 E V 3 of weight w(u,v) if and only if color(u) = color(u) = C2. 

Consider two nodes x,y so that D[x,y] < 00. Let x' = II[x, y] and y' — H'[x, y] be the first node after x and 
the last node before y, respectively, on the path from x to y with weight D[x,y\. If {x,x') is a directed edge, then 
add an edge from x 3 E V 3 to y 1 E V 1 , just as in the directed graph construction. Similarly, if (y',y) is a directed 
edge, then add an edge from x 1 E V 1 to y 2 E V 2 . Otherwise, if (y',y) is undirected, add an edge from x 1 £ V 1 to 
y 2 E V 2 only if color(y') = C\ and color (y) = G-x- If (x, x') is undirected, add an edge from x 3 E V 3 to y 1 E V 1 only 
if color(x') = C\ and color(a;) = C2. The weights of these edges are all D[x,y]. 

By Lemma [4] (which also applies to mixed graphs) now every triangle in G' corresponds to a simple cycle of no 
larger weight. Furthermore, the minimum cycle of G is represented by a triangle of the same weight in G' with 
constant probability. This follows from the color-coding and by the fact that for some node s of C and its middle 
edge (vi,v i+ i), D[s,Vi] = d(s,Vi) = d c (s,Vi) and D[v i+ i, s] =d(v i+ i,s) = dc(vi+i, a). 

Theorem 8. Let G(V, E, w) be a mixed graph on n nodes, w : E — > {1, . . . , M}. In 0{Mn u} ) time one can construct 
O(logn) graphs Gi,...,G' k onO(n) nodes and edge weights in {1, . . . , 0(M)} so that the minimum out of all weights 
of triangles in the graphs G[ is exactly the weighted girth of G. 

Shortest paths and minimum cycles in undirected graphs with positive and negative weights are of a completely 
different nature than the corresponding problems in directed graphs or in undirected graphs with nonnegative weigths. 
In the absence of negative cycles, shortest paths and cycles can be solved via matching techniques (see e.g. [TJ1 [Tj)J 
HnHH]). However, the running times are not as good as the corresponding ones for directed graphs. For instance, 
APSP can be solved in 0(min{n 3 , mn log n}) time [10j . whereas the corresponding problem in directed graphs can 
be solved in 0(min{n 3 log log 3 n/ log 2 n, mn + n 2 \ogn\) [5l l8l [23] . 

None of the shortest paths algorithms for directed graphs, including Yuster-Zwick's algorithm, apply for undirected 
graphs when there are negative weights, as they would confuse any negative weight edge with a negative cycle. Hence 
our approach from Section[5]would not work. Our approach from Section[3]also fails, even if we have already computed 
APSP in the graph. The main reason is that Lemma [4] does not apply when the weights can be negative, and hence 
the color-coding technique cannot be applied, as is. Computing minimum cycles in undirected graphs with possibly 
negative weights may require entirely new techniques. 

Extension to fc-cycles. We now show that the minimum weight cycle problem in undirected and directed graphs 
can be reduced to the minimum fc-cycle problem in undirected graphs for every k > 4. In order to obtain our 
reduction to minimum fc-cycle in undirected graphs with integral edge weights in [0, O(M)] it suffices to provide 
a reduction from minimum weight triangle in an n-node undirected graph with weights in \—M, M] to minimum 
fc-cycle in a 0(n)-node undirected graph with edge weights in [0, 0(M)], and then to combine this reduction with 
our reduction from minimum weight cycle to minimum weight triangle. This proves Theorem [3J 

Lemma 7. Let k > 4 be fixed. Given an n-node undirected graph G with integral edge weights in [—M,M], one 
can construct in 0(n 2 ) time an undirected graph G' on O(rt) nodes and integral edge weights in [0, 6M] so that if G 
has at least one triangle and the minimum triangle weight is W , then the minimum weight k-cycle in G' has weight 
W + 15M . 

Proof. Without loss of generality, we can assume that the instance of minimum triangle is tripartite with partitions 
V 1 , V 2 , V 3 . Remove each node v E V 1 and its incident edges and replace it with a path on k — 2 nodes P v = {vi — > 
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V2 —>•... — > as follows. For every original edge (u,v) with u G V 2 , add an edge (u,vi) with weight w(u,v), 

and for every original edge (v,u) with w <G V 3 , add an edge (vk-2,u) with weight Let the weights of the 

path edges (uj, Uj+i) for i G {1, . . . , k — 3} be all 0. Increase the weights of all edges of G' which are not on paths P v 
by 5M. This forms a weighted graph G' on O(kn) nodes and weights in [0,6M]. 

Every triangle v G V 1 , u G V 2 , z G V 3 of weight IT in the original graph has a corresponding k— cycle in G" of 
weight W + 15M. Now consider any fc— cycle C of G'. If C contains an edge of a path P v corresponding to a node 
v G V 1 , then it must contain the entire path since every node Vi for i G {2, . . . , k — 3} has degree exactly 2. Hence 
C contains exactly 2 other nodes which must close a cycle with P v . Hence the other two nodes are from V 2 and V 3 , 
and there is a corresponding triangle in G of weight 15M less. 

If on the other hand C does not contain an edge of a path P v , then it has k edges of weight at least AM, and hence 
w(C) > AkM > 16M for k > 4. Any triangle of G, however, corresponds to a cycle of weight < 15M < 16M < w(C). 
Hence the minimum weight /c-cycle in G' must correspond to a triangle in G, if G contains a triangle. □ 
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